
#include <stdio.h>
#include <string.h>
#include <mysql/mysql.h>

#define HOST "127.0.0.1"
#define USER "root"
#define PASS "jjx102476+"
#define PORT 3306
#define DBNAME "gobang"

int main()
{
    // 1. 初识化mysql句柄
    MYSQL* mysql = mysql_init(NULL);
    if(mysql == NULL)
    {
        printf("mysql init failed\n");
        return -1;
    }
    // 2. 连接服务器
    if(mysql_real_connect(mysql,HOST,USER,PASS,DBNAME,PORT,NULL,0) == NULL)
    {
        printf("connect mysql server failed: %s\n",mysql_error(mysql));
        mysql_close(mysql);
        return -1;
    }
    // 3. 设置客户端字符集
    if(mysql_set_character_set(mysql,"utf8") != 0)
    {
        printf("set client character failed: %s\n",mysql_error(mysql));
        mysql_close(mysql);
        return -1;
    }

    // 4. 选择要操作的数据库
    // mysql_select_db(mysql,DBNAME);       //因为在上面已经选择过了，这里就不选了

    // 5. 执行sql语句
    // char* sql = "insert stu values(null,'张三',18,87,89.5,90);";    //增加
    // char* sql = "update stu set ch=95 where sn=1;";    //修改
    // char* sql = "delete from stu where sn=1;";    //删除
    char* sql = "select * from stu;";    //查找

    int ret = mysql_query(mysql,sql);
    if(ret != 0)
    {
        printf("%s\n",sql);
        printf("mysql query failed: %s\n",mysql_error(mysql));
        mysql_close(mysql);
        return -1;
    }
    // 6. 如果sql语句是查询语句,则需要保存结果到本地
    MYSQL_RES* res = mysql_store_result(mysql);
    if(res == NULL)
    {
        mysql_close(mysql);
        return -1;
    }
    // 7. 获取结果集中的结果条数
    int num_row = mysql_num_rows(res);
    int num_col = mysql_num_fields(res);
    // 8. 遍历保存到本地的结果集
    for(int i = 0; i < num_row; ++i)
    {
        MYSQL_ROW row = mysql_fetch_row(res);
        for(int i = 0; i < num_col; ++i )
        {
            printf("%s\t",row[i]);
        }
        printf("\n");
    }
    // 9. 释放结果集
    mysql_free_result(res);
    // 10. 关闭连接,释放句柄
    mysql_close(mysql);
    return 0;
}